package qjc.a_哈希;

import java.util.HashMap;

public class a_两数之和 {
    /**
     * 定义一个哈希表，存储每个target-nums[i]的值，如果存在，则返回结果，
     * 不存在则将nums[i]存入哈希表
     */
    public int[] twoSum(int[] nums, int target) {
        HashMap<Integer,Integer> map = new HashMap<>();
        for (int i = 0; i < nums.length; i++) {
            int k = target - nums[i];
            if (map.containsKey(k)) {
                return new int[]{map.get(k), i};
            }
            map.put(nums[i],i);
        }
        return null;
    }
}
